/***************************************************************************/
/* Procedimiento: ?NomProcedimientoInsertar
/* Descripcion:   Insertar o Modifica una fila en la tabla ?Esquema?NomTabla
/* Parametros:    ?InfoParametros
/*                pTransaccion. Numero identificador de la Transaccion
/*                pMensaje. Mensaje de comfirmacion o excepcion
/* Comentarios:         
/****************************************************************************/

PROCEDURE ?NomProcedimientoInsertarModificar(?Parametros pTransaccion OUT NUMBER, pMensaje OUT VARCHAR2)
AS
vExisteRegistro NUMBER(1);
BEGIN
  SELECT count(*)
  INTO   vExisteRegistro
  FROM   ?Esquema?NomTabla
  WHERE  nidDocumento=pNidDocumento;
  
  IF vExisteRegistro=0 THEN
    INSERT INTO ?Esquema?NomTabla
	           (?CamposBaseDatos)
    VALUES     (seq_?NomTabla.nextval, ?PValues);
  ELSE
    UPDATE ?Esquema?NomTabla
    SET    ?Igualaciones
    WHERE  ?Condicion;
  END IF;
  
  COMMIT;
  pTransaccion := 1;
  pMensaje := 'Terminado OK';
  dbms_output.put_line('Terminado OK');

EXCEPTION
  WHEN OTHERS THEN
    pTransaccion := 0;
    pMensaje := 'Error en ?NomProcedimiento_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm;
    dbms_output.put_line('Error en ?NomProcedimiento_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm);
END;